﻿//==================================================================
// Copyright (C) 2011 深圳市中旭企业管理股份有限公司
// 文件名: DatPositions.cs
// 作 者：代码自动生成
// 日 期：2012-5-21 15:46:38
// 描 述：
// 版 本：1.00
// 修改历史纪录
// 版 本  修改时间      修改人            修改内容
// 1.00             
//==================================================================
using System;
using System.Collections.Generic;
using System.Linq;
using System.ComponentModel;
using System.Text;
using Csla;
using lite;
using Csla.Validation;
using Csla.Data;
using System.Data.SqlClient;
using ZX.DAL;
using OpenExpressApp.ORM;

namespace ZX.EHR.Library
{
    /// <summary>
    /// 职位表
    /// </summary>
    [Serializable]
    [Table(Name = "DatPositions")]
    [ZX.DBModule.Table("DatPositions", "PositionID")]
    public class DatPositions : ZX.DBModule.BaseEntity
    {

        #region Business Methods 业务方法

        /// <summary>
        /// 职位代号
        /// </summary>
        private static PropertyInfo<Guid> PositionIDProperty = RegisterProperty(typeof(DatPositions), new PropertyInfo<Guid>("PositionID"));
        [DataObjectField(true, true)]
        [Column, PK]
        public Guid PositionID
        {
            get { return GetProperty(PositionIDProperty); }
            set { SetProperty(PositionIDProperty, value); }
        }

        /// <summary>
        /// 职位名称
        /// </summary>
        private static PropertyInfo<string> PositionNameProperty = RegisterProperty(typeof(DatPositions), new PropertyInfo<string>("PositionName"));
        [Column]
        public string PositionName
        {
            get { return GetProperty(PositionNameProperty); }
            set { SetProperty(PositionNameProperty, value); }
        }
        /// <summary>
        /// 公司ID
        /// </summary>
        private static PropertyInfo<Guid> CompanyIDProperty = RegisterProperty(typeof(DatPositions), new PropertyInfo<Guid>("CompanyID"));
        [Column]
        public Guid CompanyID
        {
            get { return GetProperty(CompanyIDProperty); }
            set { SetProperty(CompanyIDProperty, value); }
        }
        /// <summary>
        /// 职能编号
        /// </summary>
        private static PropertyInfo<string> JFCodeProperty = RegisterProperty(typeof(DatPositions), new PropertyInfo<string>("JFCode"));
        [Column]
        public string JFCode
        {
            get { return GetProperty(JFCodeProperty); }
            set { SetProperty(JFCodeProperty, value); }
        }
        /// <summary>
        /// 职等ID
        /// </summary>
        private static PropertyInfo<Guid> LevelIDProperty = RegisterProperty(typeof(DatPositions), new PropertyInfo<Guid>("LevelID"));
        [Column]
        public Guid LevelID
        {
            get { return GetProperty(LevelIDProperty); }
            set { SetProperty(LevelIDProperty, value); }
        }
        /// <summary>
        /// 职务ID
        /// </summary>
        private static PropertyInfo<Guid> PTypeIDProperty = RegisterProperty(typeof(DatPositions), new PropertyInfo<Guid>("PTypeID"));
        [Column]
        public Guid PTypeID
        {
            get { return GetProperty(PTypeIDProperty); }
            set { SetProperty(PTypeIDProperty, value); }
        }
        /// <summary>
        /// 简称
        /// </summary>
        private static PropertyInfo<string> ShortNameProperty = RegisterProperty(typeof(DatPositions), new PropertyInfo<string>("ShortName"));
        [Column]
        public string ShortName
        {
            get { return GetProperty(ShortNameProperty); }
            set { SetProperty(ShortNameProperty, value); }
        }
        /// <summary>
        /// 状态
        /// </summary>
        private static PropertyInfo<string> StatusProperty = RegisterProperty(typeof(DatPositions), new PropertyInfo<string>("Status"));
        [Column]
        public string Status
        {
            get { return GetProperty(StatusProperty); }
            set { SetProperty(StatusProperty, value); }
        }
        /// <summary>
        /// 在组织中的位置(部门ID,层次)
        /// </summary>
        private static PropertyInfo<Guid> DeptIDProperty = RegisterProperty(typeof(DatPositions), new PropertyInfo<Guid>("DeptID"));
        [Column]
        public Guid DeptID
        {
            get { return GetProperty(DeptIDProperty); }
            set { SetProperty(DeptIDProperty, value); }
        }
        /// <summary>
        /// 
        /// </summary>
        private static PropertyInfo<Guid> ParentIDProperty = RegisterProperty(typeof(DatPositions), new PropertyInfo<Guid>("ParentID"));
        [Column]
        public Guid ParentID
        {
            get { return GetProperty(ParentIDProperty); }
            set { SetProperty(ParentIDProperty, value); }
        }
        /// <summary>
        /// 
        /// </summary>
        private static PropertyInfo<int> WorkOutProperty = RegisterProperty(typeof(DatPositions), new PropertyInfo<int>("WorkOut"));
        [Column]
        public int WorkOut
        {
            get { return GetProperty(WorkOutProperty); }
            set { SetProperty(WorkOutProperty, value); }
        }
        /// <summary>
        /// 
        /// </summary>
        private static PropertyInfo<DateTime> EffectiveDateProperty = RegisterProperty(typeof(DatPositions), new PropertyInfo<DateTime>("EffectiveDate"));
        [Column]
        public DateTime EffectiveDate
        {
            get { return GetProperty(EffectiveDateProperty); }
            set { SetProperty(EffectiveDateProperty, value); }
        }

        #endregion

        #region Validation Rules 验证规则
        //将验证规则与业务对象的属性联系在一起
        protected override void AddBusinessRules()
        {
            //AddRule的第一个参数是委托变量，也就是说是方法的变量
            ValidationRules.AddRule(CommonRules.StringRequired, "PositionName");
            ValidationRules.AddRule(CommonRules.StringMaxLength, new Csla.Validation.CommonRules.MaxLengthRuleArgs("PositionName", 100));
            ValidationRules.AddRule(CommonRules.StringRequired, "JFCode");
            ValidationRules.AddRule(CommonRules.StringMaxLength, new Csla.Validation.CommonRules.MaxLengthRuleArgs("JFCode", 10));
            ValidationRules.AddRule(CommonRules.StringRequired, "ShortName");
            ValidationRules.AddRule(CommonRules.StringMaxLength, new Csla.Validation.CommonRules.MaxLengthRuleArgs("ShortName", 20));
            ValidationRules.AddRule(CommonRules.StringRequired, "Status");
            ValidationRules.AddRule(CommonRules.StringMaxLength, new Csla.Validation.CommonRules.MaxLengthRuleArgs("Status", 1));
            //base.AddBusinessRules();
        }
        #endregion

        #region Factory Methods 工厂方法

        public DatPositions() { }

        public static DatPositions New()
        {
            return DataPortal.Create<DatPositions>();
        }
        public static DatPositions Get(Guid PositionID)
        {
            return DataPortal.Fetch<DatPositions>(new SingleLazyCriteria<DatPositions, Guid>(PositionID, false));
        }
        public static void Delete(Guid PositionID)
        {
            DataPortal.Delete(PositionID);
        }

        //public override DatPositions Save()
        //{
        //return base.Save();
        //}
        #endregion

        #region Data Access 数据访问
        //由于DataPortal_create中没有对数据库的访问，所有标记了Runlocal特性，使得该方法只需在本地运行即可
        //如果代码中有访问数据库的方法，那么就不要用这个特性，使数据门户可以根据情况将此方法的运行选择在应用服务器还是本地
        [RunLocal()]
        protected override void DataPortal_Create()
        {
            //在此调用CheckRules对所有的属性进行验证规则的检查，这样检查只运行一次。
            ValidationRules.CheckRules();
        }


        //可以看到此方法没有标记任何特性
        //此方法要访问数据库所以不能标记本地，由于她没有任何数据库更新操作所以也无需事务性的保护
        //此方法调用结束后会隐含的调用MarkOld（）方法
        private void DataPortal_Fetch(Guid PositionID)
        {
            //通过连接字符串建立SQL连接对象，Using符号代表，范围释放的意思，SqlConnection对象会在此范围后被释放掉
            using (var ctx = ConnectionManager<SqlConnection>.GetManager(ConnectionStringNames))
            {
                IDb db = DbFactory.Instance.GetDb(ctx.Connection);
                IQuery q = db.Query();
                q.Constrain("PositionID").Equal(PositionID);
                var data = db.Select<DatPositions>(q)[0];
                LoadProperty(PositionIDProperty, data.PositionID);
                LoadProperty(PositionNameProperty, data.PositionName);
                LoadProperty(CompanyIDProperty, data.CompanyID);
                LoadProperty(JFCodeProperty, data.JFCode);
                LoadProperty(LevelIDProperty, data.LevelID);
                LoadProperty(PTypeIDProperty, data.PTypeID);
                LoadProperty(ShortNameProperty, data.ShortName);
                LoadProperty(StatusProperty, data.Status);
                LoadProperty(DeptIDProperty, data.DeptID);
                LoadProperty(ParentIDProperty, data.ParentID);
                LoadProperty(WorkOutProperty, data.WorkOut);
                LoadProperty(EffectiveDateProperty, data.EffectiveDate);
            }
        }

        [Transactional(TransactionalTypes.TransactionScope)]
        protected override void DataPortal_DeleteSelf()
        {
            //依然是调用下面的方法删除的，只是他此时可以获得自己的Id
            DataPortal_Delete(PositionIDProperty);
        }
        #endregion

    }
}

